// 可以把题转换成：
// 找出最长子数组，其中0的个数不超过k个
// 这样就可以用双指针轻松解决
class Solution {
    public int longestOnes(int[] nums, int k) {
        int len = nums.length;
        int ret = 0, count = 0, left = 0, right = 0;
        while (right < len) {
            if (nums[right] == 0) count++;
            while (count > k) {
                if (nums[left] == 0) count--;
                left++;
            }
            ret = Math.max(ret, right - left + 1);
            right++;
        }
        return ret;
    }
}